Backdrop

프로그래머스 ▸ 코딩 기초 트레이닝

문자열 뒤집기
0

문제 설명

문자열 my_string과 정수 s, e가 매개변수로 주어질 때, my_string에서 인덱스 s부터 인덱스 e까지를 뒤집은 문자열을 return 하는 solution 함수를 작성해 주세요.

제한사항

  • my_string은 숫자와 알파벳으로만 이루어져 있습니다.
  • 1 ≤ my_string의 길이 ≤ 1,000
  • 0 ≤ se < my_string의 길이

입출력 예

my_stringseresult
"Progra21Sremm3"612"ProgrammerS123"
"Stanley1yelnatS"410"Stanley1yelnatS"

입출력 예 설명

입출력 예 #1

  • 예제 1번의 my_string에서 인덱스 6부터 인덱스 12까지를 뒤집은 문자열은 "ProgrammerS123"이므로 "ProgrammerS123"를 return 합니다.

입출력 예 #2

  • 예제 2번의 my_string에서 인덱스 4부터 인덱스 10까지를 뒤집으면 원래 문자열과 같은 "Stanley1yelnatS"이므로 "Stanley1yelnatS"를 return 합니다.

풀이

이론

String.prototype.slice()

slice() 메소드는 문자열의 일부를 추출하면서 새로운 문자열을 반환해요.

str.slice(beginIndex[, endIndex])
  • beginIndex 또는 endIndex가 음수인 경우, 문자열의 끝에서부터의 길이를 나타내요.
  • endIndex가 생략된 경우, 문자열 마지막까지 추출해요.
const str = 'The quick brown fox jumps over the lazy dog.';
 
console.log(str.slice(31));
// Expected output: "the lazy dog."
 
console.log(str.slice(4, 19));
// Expected output: "quick brown fox"
 
console.log(str.slice(-4));
// Expected output: "dog."
 
console.log(str.slice(-9, -5));
// Expected output: "lazy"

코드

function solution(my_string, s, e) {
  return (
    my_string.slice(0, s) +
    [...my_string.slice(s, e + 1)].reverse().join('') +
    my_string.slice(e + 1)
  );
}